<template>
  <div class="employees-container">
    <div class="app-container">
      <PageTools>
        <template #left>
          <span>总记录数: {{ total }} 条</span>
        </template>

        <!--
          $router.push('/import?type=user')

          this.$router.push({
            path: '/import',
            query: {
              type: 'user,
              msg: 'xxx'
            }
          })
         -->
        <template #right>
          <el-button v-if="checkBtnPerm('POINT_EXCEL_IMPORT')" type="warning" size="small" @click="$router.push('/import?type=user')">excel导入</el-button>
          <el-button v-if="checkBtnPerm('POINT_EXCEL_EXPORT')" type="danger" size="small" @click="handleDownload">excel导出</el-button>
          <el-button type="primary" size="small" @click="clickAdd">新增员工</el-button>
        </template>
      </PageTools>

      <el-card v-loading="loading" style="margin-top: 10px;">
        <el-table :data="list" border>
          <el-table-column label="序号" type="index" :index="indexFn" width="80" sortable />
          <el-table-column label="头像" sortable>
            <template #default="{ row }">
              <img
                v-imgerror="errorImg"
                class="staffPhoto"
                :src="row.staffPhoto || defaultImg"
                alt=""
                @click="show2CodeDialog(row.staffPhoto)"
              >
            </template>
          </el-table-column>
          <el-table-column label="姓名" prop="username" sortable />
          <el-table-column label="手机号" prop="mobile" sortable />
          <el-table-column label="工号" prop="workNumber" sortable />
          <el-table-column label="聘用形式" :formatter="formatFn" prop="formOfEmployment" sortable />
          <el-table-column label="部门" prop="departmentName" sortable />
          <el-table-column label="入职时间" sortable>
            <template #default="{ row }">
              {{ row.timeOfEntry | formatTime }}
            </template>
          </el-table-column>
          <el-table-column label="操作" sortable fixed="right" width="280">
            <!-- <slot name="default" /> -->
            <template #default="{row}">
              <el-button :disabled="!checkBtnPerm('POINT_USER_EDIT')" type="text" size="small" @click="$router.push('/employees/detail/' + row.id)">查看</el-button>
              <el-button type="text" size="small">转正</el-button>
              <el-button type="text" size="small">调岗</el-button>
              <el-button type="text" size="small">离职</el-button>
              <el-button type="text" size="small" @click="clickAssignRole(row.id)">角色</el-button>
              <el-button :disabled="!checkBtnPerm('POINT_USER_DELETE')" type="text" size="small" @click="del(row.id)">删除</el-button>
            </template>
          </el-table-column>
        </el-table>
        <!-- 分页组件 -->
        <div style="height: 60px; margin-top: 10px">
          <el-pagination
            :current-page="page"
            :page-sizes="[1,2,3,4,5,6,7,8,9,10]"
            :page-size="size"
            layout="total, sizes, prev, pager, next, jumper"
            :total="total"
            @size-change="handleSizeChange"
            @current-change="handleCurrentChange"
          />
        </div>

      </el-card>

      <!-- <Jack>
          <Son></Son>
      </Jack> -->

      <!-- 新增员工 的对话框 -->
      <!-- 放权 -->
      <AddEmployee
        :show-dialog.sync="isShow"
        @add-employee="getUserList"
      />

      <!-- 二维码对话框 -->
      <el-dialog
        width="400px"
        title="二维码预览图片"
        :visible="show2CodeImg"
        @close="show2CodeImg = false"
      >
        <!-- 用于绘制复杂的二维码, 作为二维码的容器 -->
        <div style="text-align: center">
          <canvas ref="myCanvas" />
        </div>
      </el-dialog>

      <!-- 分配角色的对话框 组件 -->
      <AssignRole :show-role-dialog.sync="showRoleDialog" :user-id="userId" />
    </div>
  </div>
</template>
<script>
import { reqDelEmployee, reqGetUserList } from '@/api/employee'
import AssignRole from './components/AssignRole.vue'
// 默认导入
import obj from '@/constant/employees'
import AddEmployee from './components/AddEmployee.vue'
import dayjs from 'dayjs'
import errorImg from '@/assets/common/bigUserHeader.png'
// 装包 => 导包 => 调用方法
import QrCode from 'qrcode'
// QrCode.toCanvas(canvas容器, 信息='www.baidu.com') => 得到二维码
// html5 画布标签canvas  用于绘制复杂的图像 => echarts

// 直接导入 不好 ! 用户可能压根不需要导出
// import {} from '@/vendor/Export2Excel'

import hello from '@/mixins/hello'
import check from '@/mixins/check'

export default {
  name: 'Employees',
  components: {
    AddEmployee,
    AssignRole
  },
  mixins: [hello, check],
  data() {
    return {
      page: 1,
      size: 5,
      list: [],
      total: 0,
      loading: false, // card的loading效果
      isShow: false, // 新增员工对话框 显示/隐藏
      defaultImg: 'https://dss0.bdstatic.com/70cFuHSh_Q1YnxGkpoWK1HF6hhy/it/u=2146034403,1504718527&fm=26&gp=0.jpg',
      errorImg,
      show2CodeImg: false,
      showRoleDialog: false,
      userId: '' // 记录当前分配角色的用户id
    }
  },
  created() {
    // 如果此时有一大段逻辑需要 执行
    // console.log('大家好, 我是一个新组件')
    this.getUserList()
  },
  methods: {
    clickAdd() {
      // 有没有权限
      if (!this.checkBtnPerm('POINT_USER_ADD')) {
        // 没有权限
        this.$message.error('你暂时没有该权限, 请联系管理员添加此权限')
        return
      }
      this.isShow = true
    },

    async getUserList() {
      this.loading = true
      const { data: { total, rows }} = await reqGetUserList(this.page, this.size)
      // console.log(res, 666655)
      this.list = rows
      this.total = total
      this.loading = false
    },
    handleSizeChange(val) {
      // 每页条数变化触发
      this.size = val
      // 规范
      this.page = 1
      this.getUserList()
      // console.log(`每页 ${val} 条`)
    },
    handleCurrentChange(val) {
      // 页码变化时触发
      this.page = val
      this.getUserList()
      // console.log(`当前页: ${val}`)
    },
    indexFn(val) {
      //  val 0 1 2 ...
      return val + 1 + (this.page - 1) * this.size
    },
    formatFn(row, column, cellValue, index) {
      // console.log(row, column, cellValue, index, '------')
      // if (cellValue === 1) {
      //   return '正式工'
      // } else {
      //   return '临时工'
      // }
      // 1.将来项目中还会有这种逻辑的判断 ,
      // 2. 聘用形式会丰富
      // constant 常量文件
      // js 解构
      const { hireType } = obj

      const res = hireType.find(item => item.id === +cellValue)

      return res ? res.value : '未知'
    },
    del(id) {
      this.$confirm('你确定要删除他么, 继续???', '提示', { type: 'warning' }).then(async() => {
        await reqDelEmployee(id)
        // console.log(res, 88888)
        this.$message.success('删除成功')

        if (this.list.length === 1 && this.page > 1) {
          this.page--
        }

        // 发送请求 获取最新的数据 渲染
        this.getUserList()
      }).catch(() => {
        console.log('取消')
      })
    },
    async handleDownload() {
      // 表头
      //                 ['姓名', '主要信息', '     ', '      ', '     ', '      ', '部门']
      const headersArr = ['姓名', '手机号', '入职日期', '聘用形式', '转正日期', '工号', '部门']

      // 中英文对照关系
      const headersRelations = {
        '姓名': 'username',
        '手机号': 'mobile',
        '入职日期': 'timeOfEntry',
        '聘用形式': 'formOfEmployment',
        '转正日期': 'correctionTime',
        '工号': 'workNumber',
        '部门': 'departmentName'
      }

      // 发请求 获取所有的员工数据 => 分页的接口
      const { data: { rows }} = await reqGetUserList(1, this.total)
      // rows => [ {} , {}]  => [ [], [], [], [] ]
      console.log(rows, 8888777)

      const resArr = this.transArrayTo2Wei(headersArr, headersRelations, rows)
      console.log(resArr, '======')

      // 复杂表头
      const multiHeader = [['姓名', '主要信息', '', '', '', '', '部门']]
      // 合并单元格
      const merges = ['A1:A2', 'B1:F1', 'G1:G2']

      // 动态导入
      import('@/vendor/Export2Excel').then(excel => {
        console.log(excel, 9999)
        excel.export_json_to_excel({
          // 表格的表头
          header: headersArr,
          // 表格的主体数据 => 规范!! 不能乱写 二维数组
          data: resArr,
          // 文件名
          filename: '员工信息表',
          // 宽度自适应
          autoWidth: true,
          // 文件的后缀名
          bookType: 'xlsx',
          // 设置多表头
          multiHeader,
          // 设置单元格的合并
          merges
        })
      })

      // ['姓名', '学号', '年龄', '描述'],
      // [
      //  ['姓名', '学号', '年龄', '描述'],
      //  ['姓名', '学号', '年龄', '描述'],
      //  ['姓名', '学号', '年龄', '描述'],
      //  ['姓名', '学号', '年龄', '描述'],
      // ]
    },
    // 封装一个方法 , [{}, {} ..] => [[],[],[]...] 二维数组
    transArrayTo2Wei(headersArr, headersRelations, rows) {
      // 认知1:  rows.length  决定了小数组有多少个
      // 认知2:  表头的长度 决定了小数组的长度
      // console.log(headersArr, headersRelations, rows)

      const res = []

      rows.forEach(item => {
        // item => 每一项用户信息
        const arr = []

        headersArr.forEach(key => {
          // key => 中文键 => 英文键
          const englishKey = headersRelations[key]

          let val = item[englishKey]
          // 需求1: 如果发现这是在处理时间, 处理成年月日
          // if (englishKey === 'timeOfEntry' || englishKey === 'correctionTime') {
          if (['timeOfEntry', 'correctionTime'].includes(englishKey)) {
            val = dayjs(val).format('YYYY年MM月DD日')
          }
          // 需求2: 如果发现处理的是聘用形式, 把对应的文字描述展示出来
          if (englishKey === 'formOfEmployment') {
            const { hireType } = obj
            const result = hireType.find(v => v.id === +val)
            val = result ? result.value : '未知'
          }

          arr.push(val)
        })

        res.push(arr)
      })

      return res
    },
    show2CodeDialog(imgUrl) {
      if (!imgUrl) return

      // 显示对话框
      this.show2CodeImg = true
      console.log(imgUrl)

      // 获取dom(dom是异步更新)
      this.$nextTick(() => {
        QrCode.toCanvas(this.$refs.myCanvas, imgUrl)
      })
    },
    clickAssignRole(id) {
      // 弹窗显示
      this.showRoleDialog = true
      this.userId = id
    }
  }
}
</script>

<style lang="scss" scoped>
.employees-container {
  .staffPhoto {
    width: 70px;
    height: 70px;
    border-radius: 50%;
  }
}

</style>
